草庐IT

java - 使用 keytool 生成 128 位 key

全部标签

Ruby:在代码中使用 rand() 但编写测试来验证概率

我有一些代码可以根据加权随机数提供内容。权重越大的东西越有可能被随机选择。现在作为一名优秀的ruby​​ist,我当然想用测试覆盖所有这些代码。我想测试是否根据正确的概率获取了东西。那么我该如何测试呢?为应该是随机的东西创建测试使得很难比较实际与预期。我有一些想法,以及为什么它们不会很好地工作:在我的测试中stubKernel.rand以返回固定值。这很酷,但是rand()被调用了多次,我不确定我是否可以通过足够的控制来装备它来测试我需要的东西。多次获取随机项目,并将实际比率与预期比率进行比较。但除非我可以无限次地运行它,否则这永远不会完美,并且如果我在RNG中运气不佳,可能会间歇性地

Ruby 根据 key=>value 从数组中删除重复项

我有一个MusicalTracks数组,在这个数组中,由于在多个专辑中发布,同一首歌可以出现多次。我试图将它们从数组中删除,以便列表中只显示真正的唯一元素。哈希看起来像这样:"tracks"=>[[0]{"id"=>1,"Title"=>"Intergalactic","ArtistName"=>"BeastieBoys"},[1]{"id"=>2,"Title"=>"Intergalactic","ArtistName"=>"BeastieBoys"}]我需要一种方法来根据Title键删除重复项。无论如何要这样做? 最佳答案 如果

ruby - 使用 Net::HTTP block 形式的 HTTPS 请求——这可能吗?

要在没有block形式的情况下执行Net::HTTPhttps请求,您可以这样做:...http=Net::HTTP.new(url.host,url.port)http.use_ssl=true...但是有没有办法告诉Net::HTTP在进行block形式时使用https?u=URI.parse(url)Net::HTTP.start(u.host,u.port)do|http|#ifIputhttp.use_ssl=truehere,rubycomplainsthatthiscan't#bedonebecuasethesesionhasalreadystartedresp=http

ruby - 使用正则表达式在 Ruby 中查找精确的模式匹配

我将如何使用正则表达式测试精确匹配。"car".match(/[ca]+/)返回true。由于正则表达式模式不包含“r”,我如何让上述语句返回false?任何包含除“c”和“a”以外的任何字符的字符串都应返回false。“acacaccc”应该返回真“acacacxcc”应该返回false 最佳答案 为其添加一些anchor:/^[ca]+$/ 关于ruby-使用正则表达式在Ruby中查找精确的模式匹配,我们在StackOverflow上找到一个类似的问题:

ruby - 如何在 Ruby/Rails 中使用命名空间/子目录动态加载类?

在我的Rails3.1应用程序(使用Ruby1.9)中,我有一个Deployer1类,它位于model目录下的worker子目录中我正在尝试使用以下代码动态加载/实例化此类:clazz=item.deployer_class#deployer_classistheclassnameinastringdeployer_class=Object.const_getclazzdeployer=deployer_class.new如果我不使用namespace,例如像这样的全局名称:classDeployer1end然后它工作正常(deployer_class="Deployer1")-它可以

Ruby - 需要 'watir-webdriver' - 生成一个没有这样的文件的 LoadError ... 为什么?

我是Ruby的新手,非常感谢能帮助我理解这里发生的事情。总结:Gem安装watir-webdriver安装正常开始irb需要“watir-webdriver”...LoadError:没有要加载的文件--watir-webdriver当然这应该响应=>true为什么找不到gem?或者我做错了什么?我在win7上,Railsinstaller(Ruby1.8.7)。 最佳答案 在1.8.7中,您需要先要求ruby​​gems。require'rubygems'这里有一些解释:Howdoesrequirerubygemshelpfind

ruby - 在 ruby​​ 中合并或求和 "keys"上的 2 个数组

这是数组版本:Sum2hashesattributeswiththesamekey我有2个数组,例如:a=[[1,10],[2,20],[3,30]]b=[[1,50],[3,70]]我怎样才能对第一个值(如果存在)求和得到:c=[[1,60],[2,20],[3,100]] 最佳答案 你可以这样做:(a+b).group_by(&:first).map{|k,v|[k,v.map(&:last).inject(:+)]}首先,您使用+将数组放在一起,因为您不关心a和b,您只关心它们的元素。然后group_by按第一个元素对组合数组

Ruby 使用 rbenv 在 OSX Lion 上失败

我一直在尝试在我的Lion机器(OSX10.7.3)上安装Ruby。我安装了rbenv和ruby​​-build,并试图在我的机器上安装1.9.2-p290。这是安装失败的输出:$rbenvinstall1.9.2-p290Downloadinghttp://pyyaml.org/download/libyaml/yaml-0.1.4.tar.gz...Installingyaml-0.1.4...Installedyaml-0.1.4to/Users/CSC/.rbenv/versions/1.9.2-p290Downloadinghttp://ftp.ruby-lang.org/p

ruby - 从哈希中删除 key 的非破坏性方法

是否有从哈希中删除键值对的非破坏性方法?例如,如果你这样做了original_hash={:foo=>:bar}new_hash=original_hashnew_hash=new_hash.reject{|key,_|key==:foo}或original_hash={:foo=>:bar}new_hash=original_hashnew_hash=new_hash.dupnew_hash.delete(:foo)然后original_hash没有改变,new_hash改变了,但是它们有点冗长。但是,如果你这样做了original_hash={:foo=>:bar}new_hash

ruby - 不使用@符号访问实例变量

这是书中的一个例子:classTextCompressorattr_reader:unique,:indexdefinitialize(text)@unique=[]@index=[]add_text(text)enddefadd_text(text)words=text.splitwords.each{|word|add_word(word)}enddefadd_word(word)i=unique_index_of(word)||add_unique_word(word)@index在方法add_unique_word中,作者访问了变量unique而没有使用@符号(unique.s